Docker 部署 Web
编写 Dockerfile
- 最简单方式是在项目根目录编写
Dockerfile
Dockerfile
FROM node:16-alpine AS builder
WORKDIR /web
COPY . /web
# 分离环境
RUN cd /web
# 添加国内源加速下载
RUN npm config set registry https://registry.npmmirror.com
# 本项目使用 pnpm 管理包, 根据你的实际来修改
RUN npm install pnpm -g
# 验证 pnpm安装与否
RUN pnpm -v
# 删除 npm 下载的包,由 pnpm 接管
RUN rm -f node_modules
# 安装依赖
RUN pnpm install
# RUN pnpm install --no-frozen-lockfile 不根据package.lock的包来下载
# 处理下载出错
RUN RET=$? if [[ RET -ne 0 ]]; then tail -n 100 $HOME/.npm/_logs/*.log; exit $RST; fi;
# 打包
RUN pnpm build
# 使用nginx代理 web 项目的映射
FROM nginx:latest
# 把上一步骤打包好的的 dist目录传递到 nginx 默认的 html 目录作为映射
COPY --from=builder /web/dist/ /usr/share/nginx/html/
# 挂载 Nginx 的必要文件,
# /etc/nginx/ssl/是 SSL 配置,不需要删掉即可
# /var/log/nginx/ 是 nginx 日志,不需要删掉即可
# /var/cache/nginx/是 nginx 缓存, 不需要删掉即可
# /etc/nginx/conf/ 是 nginx 的配置文件, 必须保留
# /usr/share/nginx/html/是 nginx 的 html 目录, 必须保留
VOLUME ["/var/cache/nginx/", "/etc/nginx/ssl/", "/etc/nginx/conf/", "/etc/nginx/conf/nginx.conf", "/var/log/nginx/", "/usr/share/nginx/html/"]
# 映射的端口
EXPOSE 80
EXPOSE 443
# 运行 nginx 服务
CMD ["nginx", "-g", "daemon off;"]
- 构建 Docker 镜像
将
image
:web
# 这里需要替换成你使用Docker build
的名字
语法:
docker build [--progress=plain] [--no-cache] -t <image_name> <path>
例: 在当前目录构建所有文件, 镜像名为web
, 不使用Docker
缓存, 显示构建过程的详细信息
- --progress=plain: 构建过程中显示的详细信息的格式
- --no-cache : 不使用缓存
- web : 构建的镜像名
- . : 当前目录所有文件
docker build --progress=plain --no-cache -t web .
如果不在当前目录, 使用选项
-f
例:
docker-compose -f ./build/ci/frontent/docker-compose.yml up -d
编写 Nginx 配置文件
创建 nginx
的目录, html
与conf
目录是必要的, 其他为可选
mkdir -p /home/nginx/html
mkdir -p /home/nginx/conf
mkdir -p /home/nginx/ssl
mkdir -p /home/nginx/log
编写docker-compose
- 创建
docker-compose.yml
文件:
docker-compose.yml
version: '3'
services:
nginx:
image: web # 这里需要替换成你的镜像名
ports:
- "80:80"
- "443:443"
restart: unless-stopped
volumes:
- /home/nginx/cache:/var/cache/nginx
- /home/nginx/ssl:/etc/nginx/ssl
- /home/nginx/conf:/etc/nginx/conf
- /home/nginx/log:/var/log/nginx
container_name: nginx
- 部署:
docker-compose up -d
选项
一些选项参考:
- down: 停止运行
docker-compose -f ./build/ci/frontent/docker-compose.yml down
- --build:
--build
:这是docker-compose up
命令的另一个选项,它表示在启动容器之前需要构建镜像。如果在之前的构建中没有更改过镜像,docker-compose
将重用现有的镜像,但使用--build
选项可以强制进行镜像构建,以确保使用最新的代码和配置。
docker-compose up -d --build